<template>
	<div class="dict-group" v-loading="loading">
		<div class="head">
			<span>类型</span>
			<el-button
				type="success"
				bg
				size="small"
				v-permission="service.dict.type.permission.add"
				@click="edit()"
				>添加</el-button
			>
		</div>

		<div class="list">
			<el-scrollbar>
				<ul>
					<li
						v-for="(item, index) in list"
						:key="index"
						class="item"
						:class="{
							'is-active': active == item.id
						}"
						@click="select(item)"
						@contextmenu="
							(e) => {
								onContextMenu(e, item);
							}
						"
					>
						<span>{{ item.name }} - {{ item.key }}</span>
						<el-icon v-show="active == item.id"><arrow-right-bold /></el-icon>
					</li>

					<el-empty v-if="list.length == 0" :image-size="80" />
				</ul>
			</el-scrollbar>
		</div>

		<!-- 表单 -->
		<cl-form :ref="setRefs('form')" />
	</div>
</template>

<script lang="ts" setup>
import { ElMessage, ElMessageBox } from "element-plus";
import { inject, onMounted, ref } from "vue";
import { ArrowRightBold } from "@element-plus/icons-vue";
import { checkPerm } from "/$/base";
import { ContextMenu } from "cl-admin-crud-vue3";
import { useCool } from "/@/core";

const { refs, setRefs, service } = useCool();
const form = ref<any>({});
// 字典
const dict = inject<any>("dict");

// 选中
const active = ref("");

// 列表
const list = ref<any[]>([]);

// 加载状态
const loading = ref(false);

const viewGroup = inject<any>("viewGroup");

// 刷新
async function refresh() {
	loading.value = true;

	await service.dict.type.list().then((res) => {
		list.value = res;

		if (!active.value) {
			select(res[0]);
		}
	});

	loading.value = false;
}

// 选择
function select(item: any) {
	active.value = item?.id;

	// 设置
	dict.setGroup(item);

	// 刷新
	dict.refresh({
		typeId: active.value,
		page: 1
	});

	// viewGroup.checkExpand(false);
}

// 编辑
function edit(item?: any) {
	refs.value.form?.open({
		title: item ? "编辑类型" : "添加类型",
		width: "500px",
		props: {
			labelWidth: "60px"
		},
		items: [
			{
				label: "名称",
				prop: "name",
				component: {
					name: "el-input",
					props: {
						maxlength: 20
					}
				},
				required: true
			},
			{
				label: "Key",
				prop: "key",
				component: {
					name: "el-input",
					props: {
						maxlength: 20
					}
				},
				required: true
			}
		],
		form: {
			...item
		},
		on: {
			submit(data: any, { done, close }: any) {
				service.dict.type[item ? "update" : "add"](data)
					.then(() => {
						ElMessage.success("保存成功");
						close();
						refresh();
					})
					.catch((err: any) => {
						ElMessage.error(err.message);
						done();
					});
			}
		}
	});
}

// 右键
function onContextMenu(e: any, item: any) {
	ContextMenu.open(e, {
		'hover': {
			target: "item"
		},
		list: [
			{
				label: "编辑",
				hidden: !checkPerm(service.dict.type.permission.update),
				callback(_: any, done: Function) {
					done();
					edit(item);
				}
			},
			{
				label: "删除",
				hidden: !checkPerm(service.dict.type.permission.delete),
				callback(_: any, done: Function) {
					done();

					ElMessageBox.confirm("是否要删除该类型？", "提示", {
						type: "warning"
					})
						.then(() => {
							service.dict.type
								.delete({
									ids: [item.id]
								})
								.then(async () => {
									ElMessage.success("删除成功");

									// 刷新列表
									await refresh();

									// 删除当前
									if (active.value == item.id) {
										select(list.value[0]);
									}
								})
								.catch((err: any) => {
									ElMessage.error(err.message);
								});
						})
						.catch(() => null);
				}
			}
		]
	});
}

onMounted(() => {
	console.log(11231);
	refresh();
});
</script>

<style lang="scss" scoped>
.dict-group {
	height: 100%;
	width: 100%;
	box-sizing: border-box;
	white-space: nowrap;

	.head {
		display: flex;
		align-items: center;
		justify-content: space-between;
		height: 40px;
		font-size: 14px;
		padding: 0 10px;
	}

	.list {
		height: calc(100% - 40px);
		padding: 10px;
		box-sizing: border-box;
	}

	ul {
		li {
			display: flex;
			align-items: center;
			width: 100%;
			list-style: none;
			box-sizing: border-box;
			padding: 10px 35px 10px 10px;
			cursor: pointer;
			font-size: 14px;
			margin-bottom: 10px;
			border-radius: 3px;
			color: #666;
			position: relative;
			background-color: #f7f7f7;

			.el-icon {
				position: absolute;
				right: 10px !important;
			}

			&:last-child {
				margin-bottom: 0;
			}

			&.is-active {
				background-color: $color-primary !important;
				color: #fff;
			}

			&:hover {
				opacity: 0.8;
			}
		}
	}
}
</style>
